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ABSTRACT: 

A packet transfer control apparatus, and a scheduling method therefor, having a multi-queue 
configuration provided with a plurality of queues for storing packets, wherein, when processing to 
select and transfer the head packet having the eariiest scheduled transfer finish time from the 
head packets in N number of queues Qi to QN provided in correspondence with the respective 
fiows, a scheduler clusters head packets having a low dependency upon changes in relative 
order of the scheduled transfer finish times with respect to changes in the entire reserved 
bandwidths of the backlog queues, holds the first order packets having the eariiest scheduled 
transfer finish times among the clusters C1 to CM, reuses the output priorities in the clusters 
calculated in the past as they are at the output for transfer of the packets to calculate the 
scheduled transfer finish times for only the first order packets in the clusters among the clusters, 
and selects the packet with the eariiest calculated time as the top priority packet. 
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(54) Packet transfer control apparatus and scheduling method therefor 



(57) A paclcet transfer control apparatus, and a 
scheduling method therefor, having a multi-queue con- 
figuration provided with a plurality of queues for storing 
packets, wherein, when processing to select and trans- 
fer the head packet having the earliest scheduled trans- 
fer finish time from the head packets in N number of 
queues Qj to provided in correspondence with the 
respective flows, a scheduler clusters head packets 
having a low dependency upon changes in relative order 



of the scheduled transfer finish times with respect to 
changes in the entire reserved bandwidths of the back- 
log queues, holds the first order packets having the ear- 
liest scheduled transfer finish times among the dusters 
to C^, reuses the output priorities in the clusters cal- 
culated in the past as they are at the output for transfer 
of the packets to calculate the scheduled transfer finish 
times for only the first order packets in the clusters 
among the clusters, and selects the packet with the ear- 
liest calculated time as the top priority packet. 
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Description 

BACKGROUND OF THE INVENTION 
s 1 . Field of the Invention 

[0001] The present invention relates to a packet transfer control apparatus having a multi-queue configuration pro- 
vided with a plurality of queues for storing packets and a scheduling method therefor, more particularly relates to a 
packet transfer control apparatus for efficiently selecting and outputting a packet capable of finishing being transferred 

10 the earliest from among head packets in the queues and a scheduling method therefor. 

[0002] In a packet transfer network, in order to guarantee the quality of servk:e (QoS) for every flow (a plurality of 
consecutive packets which a user has requested the transfer of) and to utilize resources such as the transmission 
paths (bandwidth available for transmissbn) to the maximum to improve the service, it is requested that the packet 
transfer control apparatus be provided with a "weighted multi-queueing" function where it is provided with a plurality 

IS of queues corresponding to the flows and weight the queues with an order of transfer so as to control them for a fair 
packet transfer among queues and a 'fair queueing" function where remaining resources (leftover bandwidth) are fairly 
distributed among flows temporarily so as to make efficient use of the resources. 

[0003] In the case of traffic data such as file transfer protocol (FTP) data or world wide web (WWW) data, It is con- 
sidered important to transfer the data of each flow fairly at a high speed by utilizing the resources to the maximum limit. 
20 The routers etc. of gateways of the network have been required to perform high speed processing, in correspondence 
with the high speed output links, of control for alkx:ating to each flow and guaranteeing a bandwkJth reserved for each 
of these flows (or sets of flows) and. at the same time, fairly reallocating the leftover resources in output links among 
these flows. 

[0004] On the other hand, in the case of voice traffic data such as voice over IP (VoIP), it is more important that a 
25 fixed transfer rate be guaranteed and a delay jitter be minimized rather than the bandwidth of the links being used fairly 
and to the maximum limit. 

[0005] The present inventk>n deals with the transfer of packets with different required qualities of service (CtoS), 

focuses on: 

30 1) a structure for performing high speed processing of transfer order control (scheduling) of individual packets in 

accordance with different requests for quality of sen/ice for every type of the traffic data and 
2) a structure for linking these individual structures and effectively utilizing the entire bandwidth, and 
will be applied to high speed multimedia networks in the future. 

35 2. Description of the Related Art 

[0006] As the fair queueing technique, weighted fair queueing (WFQ) and start-time fair queueing (SFQ) are well 
known. 

[0007] The principle of fair queueing based on this weighted fair queueing (WFQ) will be explained in detail later by 
40 using Fig. 5. As clear from the explanation using Fig. 5, in transfer control by weighted fair queueing (WFQ), the 
scheduled transfer finish times F|^ are calculated for the respective head packets in the queues Q) (i = 1 , 2, N) and 
prk)rity is assigned to the order of output by the calculated value so as to achieve falmess of the packet transfer among 
flows and the effective utilization of resources. 

[0008] The scheduled transfer finish times F^ of the head packets in the queues Qj are cateulated by equation (1) 
45 given later. 

[0009] The calculatk^n of equation (1 ) includes the calculation of the bandwidths allocated to the queues Q. These 
vary due to the change of the backk>g queues with every transfer of a packet as shown in equatk>n (2) and equation 
(3) given later. The alkxated bandwidths rj ^ of the next head packets cannot be correctly calculated before the end of 
the output processing of the packets immediately before them. 
so [0010] Namely, whenever a new head packet is output, the calculation must be redone. In addition, the results of 
the calculations for the scheduled head packet transfer finish times Fj of the queues calculated at the time of the 
previous packet outputs cannot be used at all for the next packet outputs even for head packets remaining in the 
queues Qj without being selected. This invited an increase in the amount of calculation. 

[0011] On the other hand, known in the art is the technique of introducing virtual time in order to solve the problem 
55 of the increase of the amount of catoulation due to the change of the allocated bandwidths rj^ . By utilizing virtual time, 
equation (1) can also be represented by an equation including a virtual time V(t), a sum value of the resen/ed 
bandwidths of the backlog queues and the resource bandwidth R as will be explained later 

[0012] The virtual time V(t) is recalculated whenever the sum value 0^ of the reserved bandwidths of the backlog 
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queues and the resource bandwidth R change, but realization is easy since the scheduled transfer finish time Fj ^ can 
be determined at the time of arrival of the packet. 

[0013] When virtual time is introduced, the time axis of the scheduled transfer finish time Fj^ ends up becoming its 
own axis which is different from the actual time axis. Thus, when a plurality of schedulers for controlling the order of 

s transfer of the packets are provided in accordance with the quality of service request (QoS), the time axes end up 
becoming different among schedulers. Therefore, there is a problem that the link among schedulers, for example, the 
processing for selecting the output packet having the top priority among the schedulers, becomes difficult. 
[0014] Further, it has been sometimes pointed out that, if a control of the packet transfer is achieved by the fair 
reallocation of resources like weighted fair queueing (WFQ) without using virtual time, the amount of calculation for 

to determinffig the order of the transfer (scheduling) becomes extremely large, so rt is difficult to apply this to a high speed 
link. 

SUMMARY OF THE INVENTION 

IS [001 S] Therefore, an object of the present invention is to provide a packet transfer control apparatus, and a scheduling 
method therefor, which greatly reduce the amount of calculation for scheduling of the packet transfer in fair queueing 
for guaranteeing different qualities of sen/ice (QoS) for the respective flows and utilizing the resources of the trans- 
mission paths to the maximum limit, which enable high speed packet transfer processing, and which in addition can 
easily achieve a link among a plurality of provkied schedulers in accordance with the requested qualities of service 

20 (QoS). 

[0016] When further concretely describing this, to solve the problem, in the calculation for selecting the top priority 
packet to be output for transfer, (i) the range of the packets directly influenced by the change of the bandwidths r^j 
allocated to the queues Qj is limited so as to calculate the scheduled transfer finish times Fj^ with respect to only limited 
packets and (ii) the results of the past catoulations are reused for other packets to omit the above calculations, whereby 

2S a reduction of the amount of calculation of the weighted fair queueing (WFQ) is achieved. 

[0017] To achieve the above object, the present invention provides a packet transfer control apparatus having a 
multi-queue configuration provided with a plurality of queues each storing packets and a scheduling method therefor 
wherein, when processing to select and transfer the head packet having the earliest scheduled transfer finish time from 
the head packets In N number of queues Q| to Q^^ (1 -2) provkied in correspondence with the respective flows, a sched- 

30 uler (1-1) clusters head packets having a low dependency upon changes in relative order of the scheduled transfer 
finish times with respect to changes in the entire resented bandwidths of the backlog queues, holds the first order 
packets having the earliest scheduled transfer finish times among the clusters C-, to C^, reuses the output priorities 
in the clusters calculated in the past as they are at the output for transfer of the packets to calculate the scheduled 
transfer finish times for only the first order packets in the clusters among the clusters, and selects the packet with the 

3S earliest calculated time as the top priority packet. As a result, the amount of calculatbn for selecting the packet to be 
transferred with the top priority is greatly reduced whereby high speed packet transfer processing is enabled. 

BRIEF DESCRIPTION OF THE DRAWINGS 

40 [0018] The above object and features of the present invention will be more apparent from the following description 
of the prefen'ed embodiments given with reference to the accompanying drawings, wherein: 

Fig. 1 is an explanatory view of the principle of packet transfer control of the present inventbn; 
Fig. 2 is a graph of the relatk)nship between a scheduled transfer finish time Fj ^ and a reserved bandwidth use ratio; 
^ Figs. 3A and 3B are views of the configuratbn of a packet transfer control apparatus of the present invention; 

Fig. 4 Is an explanatory view of the packet transfer control by a plurality of schedulers in the present invention; and 
Fig. 5 Is an explanatory view of the principle of weighted fair queueing (WFQ). 



so 



DESCRIPTION OF THE PREFERRED EMBODIMENTS 



[0019] Before describing the embodiments of the present inventbn, the related art and the disadvantages therein 
will be described with reference to the related figures. 

[0020] As already explained, as fair queueing techniques, weighted fair queueing (WFQ) and start-time fair queueing 
(SFQ) are known. 

ss [0021] The principle of the fair queueing based on weighted fair queueing (WFQ) will be explained by using Fig. 5. 
In Fig. 5, 5-1 is a scheduler for packet transfer, 5-2 are meters provided in correspondence with the queues, and 5-3 
is a multi-queue comprised by N number of queues (Q^ to corresponding to the flows. 

[0022] Each queue 5-3 stores packets for every flow. The packets are processed with FIFO in each queue. The 
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scheduler 5-1 performs the processing for selecting the packet for whk^h the transfer can be finished earliest from 
among the head packets stored in the queues 5-3 and outputting this packet to the output fink. 
[0023] In this way, in transfer control by weighted fair queueing (WFQ), the scheduled transfer finish times are 
calculated for the head packets of all of the queues Qj (i = 1 , 2. .... N) and priority is assigned to the order of output by 
the thus calculated values to achieve fairness of the packet transfer among flows and effective utilization of resources. 
[0024] The scheduled transfer finish times Fj^ of the head packets in the queues Q| are calculated by the following 
equation (1): 

= max{Sj Q + Lj yr j o; tj ^ } + Lj^/r^ ^ (1 ) 



[0025] Here, max { ; } means the maximum value between the two values divided by the semicolon in the brackets. 
Further. S| q etc. are as follows. Note that the first subscript is the number of the queue (flow), and the second subscript 
is the order in the queue. 

[0026] Sj Q is the transfer start time of the packet immediately preceding the present head packet in a queue 
(hereinafter referred to as the 'preceding packet'), 

L} 0 is the packet length of the preceding packet in a queue Qj. 

rj 0 is the bandwidth allocated to a queue Q| at the time of transfer of the preceding packet in the queue 
^ tj^ is the time when the head packet in a queue Qj arrived at (is stored in) the queue Q^, 

Lj 1 is the packet length of the head packet in a queue Q;, and 

rjj Is the bandWKlth allocated to a queue Qj at the time of transfer of the head packet in the queue 

[0027] Sj 0, Li,o, L; V and tj i mentioned above are fixed values detenmined at the start of the packet transfer or the 
arrival of the packet. The values thereof are stored and held in the meters 5-2 in correspondence with the queues C^. 
but rj 0 and r^ mentioned above must be obtained by calculatbn as follows: 



Ri0 = (a»j/O^0j)XR (2) 

^i=(^/^b(i))xR (3) 

[0028] Here, Oj is the reserved bandwidth of a queue Q^, i.e., the bandwkfth allocated for the packet transfer to the 

queue Qj. 

[0029] ^b(Q) is the sum value of the reserved bandwidths forthe backlog queues at the timeof transfer of the preceding 
packet, that is, O^^q) = (j- backlog queues at the time of transfer of the preceding packet), 

Of^^y is the sum value of the resented bandwidths for the backlog queues at the time of transfer of the head 
packet, that is, <P^^^ = X<I)j Q: backlog queues at the time of transfer of the head packet), and 

R is the entire output bandwidth of the resources, where d)b(o) ^ R and <l>j,(i) ^ R stand. 
[0030] Further, the above mentioned 'backlog queue' means a queue in which at least one untransferred packet 
(backlog) is stored and is a queue in which at least one packet requiring a transfer operatk>n is stored, therefore is also 
referred to as an 'active queue'. 

[0031] The bandwidth r; allocated to each queue Qj varies according to the number of the backlog queues. As ap- 
parent from equation (2) or (3), when = R, it becomes the bandwkfth <D^, while when = a>j, it becomes the maximum 
bandwidth R. 

[0032] Here, the first term on the right side of equation (1 ) represents the transfer start reference time of the head 
packet in a queue Q^. The larger value between the transfer finish time (&, q + Lj yri q) of the preceding packet and the 
head packet arrival time tj ^ is given as the transfer start reference time. The second term on the right side of equation 
(1 ) is the time required for the transfer of the head packet. 

[0033] The scheduler 5-1 performs control for selecting and transferring the packets in the order from the one having 
the smallest value of the scheduled transfer finish time Fj^. Accordingly, the priority order of transfer is lowered for a 
queue requiring a long time for the transfer of the preceding packet and a queue with a head packet requiring a kDng 
time for the transfer, thus fair packet transfer Is carried out among queues. 

[0034] In this way, in weighted fair queueing (WFQ), the weighted control of the order of transfer by the scheduled 
transfer finish times F| is carried out with respect to the packets for all of the queues to achieve fair packet transfer 
among queues and, at the same time, unused resented bandwidths (remaining resources) are fairly allocated to active 
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queues in accordance with their reserved bandwidths to effectively reuse the resources, and thereby the packets in 
active queues are transferred at a higher speed so as to improve the service. 

[0035] However, the number of backlog queues always varies, so the bandwidths rj to be alkx:ated to the queues 
Qi always vary as well and therefore the scheduled transfer finish times f ^ ^ of the head packets in the queues Qj vary. 
5 [0036] Accordingly, the scheduler 5-1 had performed the processing for calculating the scheduled transfer finish 
times Fj ^ of the head packets by equatbn (1 ), equation (2), and equation (3) for all of the head packets in the backlog 
queues whenever one packet was output and then selecting, transferring, and outputting the head packet in the queue 
Qout with the smallest scheduled transfer finish time Fo„, ^ from among these calculated values as described in the 
foitowing equation (4): 

10 

^oul^ = min{Fi T . i : backlog queue} (4) 

[0037] The calculation of equation (1) mentioned above includes the calculatbn of the bandwidths r^ ^ and r^ ^ allo- 
cated to the queues Q}. These vary due to the change of the backlog queues with every transfer of a packet as shown 
in equation (2) and equation (3). The allocated bandwkfths rj^ of the next head packets cannot be correctly calculated 
before the end of the output processing of the packets immediately before this. 

[0038] Namely, whenever a new head packet is output, the calculation must be redone, in addition, the results of 
the calculations for the scheduled head packet transfer finish times Fj^ of the queues calculated at the time of the 
^ previous packet outputs cannot be used at all for the next packet outputs even for head packets remaining In the 
queues Qj without being selected. This invited an increase in the amount of calculation. 

[0039] On the other hand, known in the art is the technique of introducing virtual time in order to solve the problem 
of the increase of the amount of calculation due to the change of the allocated bandwidths rj ^ . By utilizing virtual time, 
equation (1) can be interpreted as: 

25 

Fj,=max{Fjo;V(ti,}} + Lj/Oj, (V) 

where, 

30 

V(ti,i) = V(tjo) + (R/<I>^)-(ti,rW 

V(0) = 0 

^ [0040] The virtual time V(t) is recalculated whenever the sum value <t>5 of the reserved bandwidths of the backlog 
queues and the resource bandwidth R change, but realization is easy since the scheduled transfer finish time F}^ can 
be determined at the time of arrival of the packet. 

[0041] However, when virtual time is introduced, the time axis of the scheduled transfer finish time Fj^ ends up 
becoming unique its own axis which is different from the actual time axis. Thus, when a plurality of schedulers for 
^ controlling the order of transfer of the packets are provided in accordance with the quality of sen/ice request (QoS), 
the time axes end up becoming different among schedulers. Therefore, there Is a problem that the link among sched- 
ulers, for example, the processing for selecting the output packet having the top priority among the schedulers, becomes 
difficult. 

[0042] Further, it has been sometimes pointed out that, if a control of the packet transfer is achieved by the fair 
^ reallocatbn of resources like weighted fair queueing (WFQ) without using virtual time, the amount of calculation for 
determining the order of the transfer (scheduling) becomes extremely large, so it is difficult to apply this to a high speed 
link, 

[0043] The present invention provides a packet transfer control apparatus, and a scheduling method therefor, which 
greatly reduce the amount of calculation for scheduling of the packet transfer in fair queueing for guaranteeing different 

^ qualities of sen^ice (QoS) for the respective flows and utilizing the resources of the transmission paths to the maximum 
limit, which enable high speed packet transfer processing, and whk:h in addition can easily achieve a link among a 
plurality of provided schedulers in accordance with the requested qualities of service (CtoS). 
[0044] When further concretely describing this, to solve the problem, In the calculation for selecting the top priority 
packet to be output for transfer, (i) the range of the packets directly influenced by the change of the bandwidths r|j 

^ alkxated to the queues Qj is limited so as to calculate the scheduled transfer finish times Fj with respect to only limited 
packets and (ii) the results of the past calculations are reused for other packets to omit the above calculations, whereby 
a reduction of the amount of calculatbn of the weighted fair queueing (WFQ) is achieved. 
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[0045] In general, the present invention provides a packet transfer control apparatus comprising: a scheduler for 
controlling the transfer by weighting the order of transfer for each head packet In the queues, the scheduler comprising: 
means for dividing each head packet in the queues into clusters In accordance with the ratio between the packet length 
of the head packet in each queue and the reserved bandwidth of the packet, and means for selecting the packet having 
s the earliest scheduled transfer finish time as the top priority transfer packet from among each first order packet InskJe 
the clusters. 

[0046] According to the present invention, (1 ) there is provided a packet transfer control apparatus provided with at 
least one scheduler which controls the transfer by weighting the order of transfer for the head packets in the queues 
in the order from the packet having the earliest scheduled transfer finish time for packets stored in a plurality of queues 

10 to which are allocated reserved bandwidths individually determined in advance and, at the same time, alkx:ating the 
resources (bandwidths) of the entire transmissk)n system to all of the active queues ^n whk:h packets to be transferred 
are stored, wherein the scheduler is provided with a clustering means for dividing the head packets in the queues into 
clusters in accordance with the ratio between the packet length of the head packet in each queue and the resented 
bandwidth (hereinafter referred to as the scheduled resource occupation time), a cluster managing means for holding 

15 the packets having the earliest scheduled transfer finish times among the packets in a cluster for all clusters as the 
first order packets, an inside-cluster selecting means for selecting the packet having the earliest scheduled transfer 
finish time for the cluster as the first order packet when a packet is deleted or added inside the cluster, and an inter- 
cluster selecting means for selecting the packet having the earliest scheduled transfer finish time as the top priority 
transfer packet from among the first order packets in the clusters. 

20 

(2) The scheduler may be provided with a reserved bandwidth use ratio computing means for computing the ratk> 
(hereinafter referred to as the reserved bandwidth use ratb) of a cumulative value of the reserved bandwidths for 
the active queues with respect to the resources (bandwidths) of the entire transmission system, and said inter- 
cluster selecting means is structured to calculate the scheduled transfer finish time based on the transfer start 

2S reference time of each first order packet, the scheduled resource occupation time, and the reserved bandwidth 

use ratio. 

(3) The inside-cluster selecting means may further be structured to sort the packets in a cluster in the order from 
the earliest scheduled transfer finish time, and the cluster managing means may be constituted so as to hold the 
packets sorted in the order from the earliest scheduled transfer finish time for every cluster 

30 (4) The inside-cluster selecting means may be structured to perform the selection by switching between processing 

for selecting only the first order packet having the earliest scheduled transfer finish time from the packets in a 
cluster and processing for sorting them in the order from the one having the earliest scheduled transfer finish time, 
perform the processing for sorting In the order from the one having the earliest scheduled transfer finish time when 
the transfer time of a packet in transmission is more than a predetemnined time, and perform the processing for 

35 selecting only the first order packet having the earliest scheduled transfer finish time when the transfer time of the 

packet in transmission is not nrKire than a predetermined time. 

(5) The inside-cluster selecting means may further be constituted so as to select the packet having the earliest 
scheduled transfer finish time based on only the transfer start reference time of each packet In the cluster or the 
transfer start reference time and the scheduled resource occupation time. 

40 (6) The insde-cluster selecting means may further be constituted so as to sort the packets in the cluster in the 

order from the one having the earliest scheduled transfer finish time based on only the transfer start reference 
time of each packet in the cluster or the transfer start reference time and the scheduled resource occupation time. 
(7) The clustering means may be constituted so as to divide the head packets in the queues into clusters by 
discriminating the type of the application packet having traffic characteristics for which the scheduled resource 

45 occupation time is specified. 

(6) The packet transfer control apparatus may be provided with a plurality of schedulers which perform different 
processing for allocation of the resources of the entire transmission system for packets stored in multi-queues 
differing for all clusters In accordance with the class of the quality of sen^ice. In this case, each scheduler is provided 
with a means for selecting the packet having the earliest scheduled transfer finish time from among the head 

50 packets for every multi-queue. Further, provision is made of a scheduler for selecting the packet having the earliest 

scheduled transfer finish time from among packets selected by the schedulers corresponding to the multi-queues. 
(9) At least one scheduler among the schedulers corresponding to the multi-queues is provided with a means for 
allocating bandwidths of a fixed rate to queues in the corresponding multi-queues and selecting the packet having 
the earliest scheduled transfer finish time. 

55 

[0047] According to another aspect of the present inventkxi, (10) there is provided a packet transfer scheduling 
method which transfers packets by weighting the order of transfer for head packets of queues in the order from the 
packet having the earliest scheduled transfer finish time for packets stored in a plurality of queues to which are allocated 
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at least reserved bandwidths individually determined in advance and, at the same time. allcx:ating resources (band- 
widths) of the entire transmission system to all of the active queues in which packets to be transferred are stored, 
comprising a step of dividing the head packets of the queues into clusters in accordance with scheduled resource 
occupation times of the head packets in the queues, a step of selecting the packet having the earliest scheduled transfer 
s finish time for a cluster as a first order packet when a packet is deleted or added to packets in the cluster and holding 
this selected packet, and a step of selecting the packet having the earliest scheduled transfer finish time from among 
the first order packets in the. clusters as a top prk^rity transfer packet. 

(11 ) The packet transfer scheduling method may further comprise a step of computing a reserved bandwidth use 
10 ratb of active queues and a step of calculating a scheduled transfer finish time during the selectbn among clusters 

based on the transfer start reference time of the first order packet, the scheduled resource occupatkxi time, and 
the reserved bandwidth use ratio. 

(12) The packet transfer scheduling method may further comprise, when achieving the selection in the clusters, a 
step of sorting the packets in a cluster in the order from the earliest scheduled transfer finish time and holding the 

IS sorted packets. 

(1 3) The packet transfer scheduling method may further comprise, when achieving the selection in the clusters, a 
step of pertormtng processing for sorting in the order from the packet having the earliest scheduled transfer finish 
time when the transfer time of a packet in transmission is more than a predetermined time and performing process- 
ing for selecting only the first order packet having the earliest scheduled transfer finish time when the transfer time 

20 of the packet in transmission is not more than a predetermined time. 

(14) The packet transfer scheduling method may further comprise, when achieving the selection in the clusters, a 
step of selecting the packet having the earliest scheduled transfer finish time based on only the transfer start 
reference time of each packet in the cluster or the transfer start reference time and the scheduled resource occu- 
pation time. 

25 (15) The packet transfer scheduling method may further comprise, when achieving the selection in the clusters, a 

step of sorting the packets In the cluster in the order from the one having the earliest scheduled transfer finish time 
based on only the transfer start reference time of each packet In the duster or the transfer start reference time 

and the scheduled resource occupation time. 

(16) The packet transfer scheduling method may further comprise, when achieving the selection in the clusters, a 
30 step of dividing the head packets of queues into clusters by discriminating the type of the application packet having 

traffic characteristics for which the scheduled resource occupation time is specified. 

[0048] Turning now to specific embodiments of the present Invention, Fig. 1 is an explanatory view of the principle 
of the packet transfer control by weighted fair queueing (WFQ) according to the present invention. In the figure, 1-1 is 
35 the scheduler for controlling transfer by clustering the packets, and 1 -2 is the multi-queue comprising N number of 
queues (Qj to Q^^) for storing packets In correspondence with flows. 

[0049] The internal structure of the queues Qj (I = 1. 2, — , N) does not have any direct bearing upon the packet 
transfer control of the present invention, so it is assumed that the queues Qj are comprised so as to perform the packet 
storing processing by the general FIFO (First in First Out) method. 

40 [0050] The scheduler 1 -1 performs the clustering of the head packets in the queues Qj (hatching part (A) in the figure) 
based on the scheduled resource occupatk>n time required for the transfer of each packet. Figure 1 shows an 
example of controlling the transfer by classifying the head packets in the queues Qj into M number of clusters to C,^. 
[0051] The scheduled resource occupation time Pj^ required for each packet transfer is calculated from the packet 
length Ljj of the head packet in each queue Qj and the reserved bandwidth 4>| of each queue Q, by the folbwing 

45 equation: 



so [0052] Namely, is the time required for transferring the packet having the packet length Lj^ under the reserved 
bandwkfth minimally albcated to the queue Q;. 

[0053] in actuality, as mentioned above, due to the weighted fair queueing (WFQ), if there is unused reserved band- 
width, that unused resented bandwkfth is also alkx:ated to the active queues with a predetermined ratio. Accordingly, 
the resource occupatbn time will become shorter than the Pjj, so the pjj will be referred to as the scheduled resource 
55 occupation time. 

[0054] The scheduler 1-1 clusters each head packets into any one of M number of clusters to C|^ in accordance 
with the values of the scheduled resource occupation times of the head packets. Figure 1 shows an example of a 
case where a head packet P^ ^ in the queue Q5 and a head packet P3 ^ in the queue Q3 are clustered into the cluster 
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C<|, a head packet P2,i in the queue Q2 and a head packet in the queue Q4 are clustered into the cluster Cg. and 
a head packet 1 in the queue is clustered into the cluster C|^. 

[0055] The scheduler 1-1 registers the head packet having the scheduled transfer finish time Fj ■, of the smallest 
value in the cluster as the first order packet to be output with the top prk>rlty in this cluster when newly incorporating 
5 a head packet in a queue into the cluster. 

[0056] Further, when the first order packet in a cluster is selected as the transfer packet and sent to the output link, 
it also registers the packet having the scheduled transfer finish time Fj j of the smallest value from among the remaining 
packets in the cluster as the first order packet in the cluster. 

[0057] In Fig. 1 . the example where the packet P2,i is sent from the cluster C2 and the next packet P2,2 is incorporated 
10 from the queue Q2 into the same cluster C2 as the head packet is shown. When packets constituting one cluster change 
in this way, the packet having the smallest value of scheduled transfer finish time Fj^ among the packets in that cluster 
(hatching part (B) in the figure) is registered as the first order packet. 

[0058] The scheduler 1-1 performs control for calculating the scheduled transfer finish times F| for the first order 
packets in the clusters (packets P5J . P2.1, ... Pi .1 of the hatching part (C) in the example of Fig. 1 ). selecting the packet 
IS having the smallest value of Fjj as the packet to be transferred with the top priority, and sending the selected packet 

from the output link. 

[0059] The principle of the packet transfer control of the present invention will be explained in further detail. The 
scheduler 1-1 shown in Fig. 1 is provided with meters (not shown) in correspondence with the queues The meters 
are set with the parameters required for calculating the scheduled transfer finish times F|j of the head packets in the 
20 queues. 

[0060] The parameters set in the meters for the queues Q| are the transfer start reference time oq 1 of the head 
packets and the scheduled resource occupation times p) -, of the head packets. The transfer start reference time a^ ^ 
of a head packet is cabulated by the following equation: 



25 



35 



40 



45 



50 



55 



Oj 1 = maxfSj 0 + Lj 0 /r^ ^ ; t ^ } (5) 



[0061] Here, Sj q + L; yr; q is the scheduled transfer finish time of the packet immediately preceding the head packet 
(preceding packet), and tj^ is the arrival time of the head packet. The transfer start reference time Oj 1 of the head 
packet becomes the larger value between values of the scheduled transfer finish time of the preceding packet and the 
arrival time of the head packet. 

[0062] The scheduled resource occupation time Is calculated by: 



Pj, = Ljya>j (6) 

as mentioned above. The scheduled resource occupation time p^ is the resource occupation time required for the 
transfer when the packets in the queues Qj are transferred with the resented bandwidth a>j as the lowest allocated 
bandwidth. The bandwidths allocated to the queues Qj vary according to the change of the backlog queues, so the 
resource occupation times also vary. Accordingly, the scheduled resource occupation time is not an actual sched- 
uled resource occupation time but one of the reference values used for the calculation of the scheduled transfer finish 
time F| 1 as will be explained later. 

[0063] The scheduler 1 -1 calculates the reserved bandwidth use ratio y of the backlog queues as the parameter for 
further calculating the scheduled transfer finish times F|j of the head packets. The resented bandwidth use ratio 7 is 
the ratio of the sum value <1>^^^ of the reserved bandwidths used by the backlog queues (active queues) with respect 
to the resources (bandwidth of entire output link) R and is calculated by the following equation: 

[0064] The scheduled transfer finish time F|j of the head packet of equation (1 ) can be modified as in the following 
equation (8) using the parameters 04 , , and yaccording to equatbn (3), equation (5). equation (6), and equation (7): 
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= + (Li ,/<I>J X (<I>j,,i,/R) 

= Ctx.i + Px.i X Y (8) 

[0065] Here, the transfer start reference time Oj;, and the scheduled resource occupation time ^ ■, are calculated at 
the time when a packet becomes the head of the queue and are fixed values which will not change later, but the 
10 reserved bandwidth use ratio y is a value changing according to the change of the backlog queues. 

[0066] When representing the relationship between the scheduled transfer finish times F|j and the reserved band- 
width use ratio Y by equation (8) in a graph, as indicated by the slanted lines in (A) of Fig. 2, the scheduled transfer 
finish times Fj ^ change linearly with respect to a change of y. 

[0067] (A) of Fig. 2 shows an example of the scheduled transfer finish times Fj (i = 1 to 4) of the head packets of 
IS the queues O, (i = 1 to 4). The points of intersection between the slanted lines and the ordinate of the figure are 04^, 
and the gradients of the slanted lines are Pi j. 

[0068] As will be understood from (A) of Fig. 2, in the case of scheduled transfer finish times Fj 1 of the packets not 
having a large difference of the gradient pj ^ of the slanted line, even if the reserved bandwidth use ratio changes, the 
probability of a change in the order of the scheduled transfer finish times F|j of these packets is k^w. Even if there is 

20 a change, the time difference is minute. 

[0069] In (A) of Fig. 2. there is not a large difference between the gradients P| of Fj^ where i = 1 and Fj^ where i = 
3 and also there is not a large difference between the gradients ft 1 of Fj ^ where i = 2 and Fjj where i = 4. In such a 
case, the relationship of magnitude between Fj ^ where i = 2 and Fj^ where i = 4 does not change when there is a 
change of the reserved bandwidth use ration Further, the relationship of magnitude between Fjj where i = 1 and Fj^ 

2S where i = 3 inverts after the two Fj ■, intersect midway, but since the gradients p|j are close to each other, a large 
difference does not occur between the values of Fjj where i = 1 and Fj^ where i = 3 per se. 

[0070] (B) of Fig. 2 is a view of only the gradient ft , . Several (for example M number of) ranges are determined in 
advance for this gradient ft -j. The clustering is carried out with respect to the head packets of the queues as mentioned 
before according to which range the gradient ^ calculated by equation (6) belongs. 
30 [0071] When performing the clustering of the head packets in this way, it is possible to make the dependency of the 
order of the scheduled transfer finish times Fj ^ of packets belonging into same cluster with respect to the change of y 
minute. 

[0072] For example, in Fig. 2, when performing the clustering while assuming that the head packets in the queues 
where i = 1 and i = 3 belong to the same cluster and that the head packets in the queues where i = 2 and i = 4 belong 

35 to the same cluster, the probability of change of the order of the scheduled transfer finish times Fj^ of the packets in 
queues Qj in the clusters cateulated when y= y^ is k>w even when y = ^ven if such a change occurs, the time 
difference thereof is small. Accordingly, even if an error occurs in the order of transfer, the influence thereof is small. 
[0073] The packet selection processing at the time of packet transfer output includes (i) processing for calculating 
the scheduled transfer finish times Fj j by equation (8) for all packets in a cluster which output a packet immediately 

40 before or a cluster to which a new head packet is added (hatching part (B) of Fig. 1 ) and selecting the first order packets 
in which the calculated scheduled transfer finish times Fj^ becomes the minimum (Inside-cluster selection processing) 
and (ii) processing for calculating the scheduled transfer finish times Fj^ by equatk)n (8) between first order packets 
in the clusters (hatching part (C) of Fig. 1 ) and selecting the packet in whk:h the calculated value becomes the minimum 
by equation (4) (inter<cluster selection processing). 

45 [0074] Since it is sufficient to perform only the processing for sending the packet selected by the selection processing 
among clusters as the top priority transfer packet to the output link, therefore the amount of catoulation can be greatly 
reduced compared with the case of the related art where the calculation of equation (8) was carried out with respect 
to the head packets In all backlog queues. 

[0075] For example, if there are 100 backlog queues, there are 100 head packets for these backlog queues. In 
so contrast to the related art where the processing for calculating the scheduled transfer finish times Fj^ by equation (8) 
for 1 00 packets and selecting the packet having the minimum calculated value, in the present invention, when assuming 
that 100 head packets are clustered into 10 clusters each comprising 10 head packets on an average, it is sufficient 
to perform the inside-cluster selection processing for an average 10 packets and the inter-cluster selection processing 
for 10 clusters. Namely, it is sufficient to calculate the scheduled transfer finish times Fj^ by equation (8) for only 20 
S5 packets, so the amount of calculation can be greatly reduced. At the same time, in the processing for selecting the 
one having the minimum calculated value as well, the number of objects to be selected Is greatly decreased, so the 
amount of processing in this selection processing can be lowered. 

[0076] In general, where the number of queues is N and the number of clusters is M, the number of the packets in 
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the cluster becomes N/M on an average. Namely, by performing the clustering as In the present invention, the calculation 
which had been carried out with respect to N number packets in the related art may be carried out by only the inside- 
cluster processing with respect to N/M number packets and the Inter-cluster processing with respect to M number of 
packets. Accordingly, since it is sufficient to carry out the calculation with respect to (N/M + M) number of packets, the 

s amount of calculation can be greatly reduced. 

[0077] Note that, In the inside-cluster selection processing mentioned above, In place of the processing for selecting 
the first order packets by the calculation of the scheduled transfer finish times Fj ^ by equation (8) using a^ ^, p^, and 
Y. the following simple processing is also possible. In a cluster, the scheduled resource occupation times Pj ^ of packets 
are values close to each other and the dependency upon the reserved bandwidth use ratioyis low, therefore packets 

10 are sorted in the order from the packet having the smallest value of the transfer start reference time ^ as the first 
sort key. Next, the packets having transfer start reference times Oi ■, of values which are the same as or ck>se to each 
other are sorted in the order from the packet having the smallest scheduled resource occupation times pj ^ as the 
second sort key. Due to this, the packet having the scheduled transfer finish time Fj ^ near the smallest value can be 
selected by simple processing without using the reserved bandwidth use ratio y. 

IS [0078] Further, by using only the value of the transfer start reference time Of j , even if the packet having the smallest 
value is selected as the first order packet, a large error will not occur in the selection result and the packet having the 
scheduled transfer finish time Fj ^ near the smallest value can be selected by further simple processing. In this case, 
the calculation of p x y is not carried out, therefore the amount of calculation for the inside-cluster processing can be 
greatly reduced. 

20 [0079] Further, in the inside-cluster selection processing, when performing selection using Ojj , Pjj , and 7 mentbned 
above or selection using only Oj 1 and pj^, it is also possible to apply (1) a procedure of registering only the selected 
first order packet, comparing the magnitude of the scheduled transfer finish times F^^ between the already registered 
first order packet and the packet to which a new packet is added when a new packet is added to the cluster, determining 
a new first order packet, and registering this, (ii) a procedure of sorting all packets in the cluster in the order from the 

25 packet having the smallest scheduled transfer finish time Fj^^, and further (ill) a procedure of switching the above 
procedures In accordance with the processing time permitted to the inside-cluster selection processing. 
[0080] In general, there is a variation in lengths of packets. By utilizing this characteristic, when packets requiring a 
long time for transfer such as long packets are sent, a large time is given for performing the calculation for selecting 
the next output packet, therefore the packets In clusters are sorted during that time. When sending short packets at 

30 high speed or in selection processing in a cluster in which there has only been deletion, but no addition of a packet, 
by using the past sorted results as they are or by switching the operation to the processing for selecting only the first 
order packets, the amount of processing can be reduced. Even in a case where consecutive short packets are output, 
high speed selection processing can be carried out without deterioration of the precision or while accompanied with 
only a slight reduction of precision. 

35 [0081] Note that whether or not a packet is one requiring a long time for transfer can be judged prior to the start of 
the sorting by division of the packet length L by the entire output bandwidth R. i.e., UH, and the comparison of the 
calculated value with a threshold value. It Is also possible to perform simple judgement by comparison of only the 
packet length with a threshold value. 

[0082] Further, when calculating the scheduled transfer finish times Fj j for selecting a first order packet in inside- 
40 cluster selection processing, the inter-cluster selection processing calculates the scheduled transfer finish times Fj ^ 
for only the first order packets of the clusters other than the cluster for which the Inside-cluster selectKtn processing is 
being carried out, compares the smallest value among these calculated values wrth the scheduled transfer finish time 
Fjj calculated in the inside-cluster selection processing, and thereby selects the top priority packet to be transferred. 
[0083] Further, in the transfer of the application packets in multimedia such as voice information or video information, 
45 in general, packets are transferred after classifying the packets into some grades in accordance with the required 
quality. 

[0084] In each above grade, the traffic characteristbs such as the resented bandwidth Oj and the packet length Lj 
are uniform. There are cases where the scheduled link occupation time Pj (P| = L/<l>j) is uniquely determined by dis- 
criminating the type of the application. In such a case, by discriminating the type of the traffic characteristic of the 

50 application packet, the clustering of the packets can be easily and correctly carried out. 

[0085] Next, an explanatk>n will be made of a concrete configuration of a packet transfer control apparatus using 
weighted fair queueing (WFQ) according to the present invention. Here, it is assumed that the packet transfer contnDl 
apparatus performs the queueing for every flow. It performs the storage processing of packets by using FIFO inside 
each queue. Further, the packet data per se is stored in a not illustrated buffer. Further, it is assumed that the packet 

55 transfer control apparatus explained below processes only pointers for the packet data per se and parameters con- 
ceming the transfer control. 

[0086] Figures 3A and 3B are views of the configuration of the packet transfer control apparatus of the present 
invention. In the figure, 3-1 is a multi-queue managing means, 3-2 is a reserved bandwidth use ratio y computing 
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means, 3-3 is a clustering means, 3-4 is a cluster managing means, 3-5 is an inside-cluster selecting means, 3-6 is 
an inter*ctuster selecting means, and 3-7 is an output control means. 

[0087] The mutti-queue managing means 3-1 is provided with queues Qj (i = 1 to N) in correspondence with flows 
and meters In correspondence wrth the queues Q|. In each queue Qj. packet tags each comprising a flow number "Flow 
s No. (j)" of the received packet, packet length 'PacketLen. (L)", arrival time (t), and a pointer of an address of the buffer 
for storing the packet data per se, are stored in the order of arrival. 

[0088] In the meter corresponding to each queue O,, the transfer start reference time ^ of the head packet of that 
queue Qj and the bandwidth a)j reserved by that queue Qj are stored. The multi-queue managing means 3-1 is provided 
with a function of managing both the queues Qj in the active state in which at least one untransferred packet (backlog) 

10 Is stored and meters corresponding to the queues and is provided with a function of outputting both the tag of the head 
packet of the corresponding queue and the parameter stored in the meter of that queue according to an output request. 
[0089] Further, it Is provided with a function of outputting the changed reserved bandwidth (±<I>) when the active state 
of a queue changes. For example, when a queue Qj changes from the inactive state to the active state, the amount of 
increase of that resented bandwidth Oj is output to the resented bandwidth use ratio y computing means 3-2. 

IS Conversely, when a queue Qj changes from the active state to the inactive state, the amount of decrease of that 
reserved bandwidth ^ is output to the reserved bandwidth use ratio y computing means 3-2. 
[0090] The resented bandwidth use ratio y computing means 3-2 is provided with both a computing unit and a y 
computing unit. The computing unit receives as its input the changed resen/ed bandwidth {±a>) from the multi-queue 
managing means 3-1 and computes the cumulative value ^ = ± of the resented bandwidths of active queues 

20 (backlog queues). 

[0091] The ycomputing unit divides the cumulative value ^ of the reserved bandwidths of the active queues (backlog 
queues) by the bandwidth R of the entire resources (output link) and computes the ratk> yof the reserved bandwidth 
a>|j used by the entire active queues (backlog queues) to the bandwidth R. 

[0092] The clustering means 3-3 is provided with both a Pj calculating unit and a clustering processing unit C(Pj). 
25 The Pj calculating unit divides the packet length Lj of the head packet In a queue Qj by the resented bandwidth 4>i of 

the queue Q-, (L/Oj) to calculate the scheduled resource occupation time p,- of the head packet. 

[0093] The clustering processing unit C(Pj) performs the processing for allocating the related packets to the clusters 
to C,^ in correspondence with ranges to which those values belong based on the values of the scheduled resource 

occupation times Pj of the related packets. 
30 [0094] The cluster managing means 3-4 Is linked to the inside-cluster selecting means 3-5 and maintains the state 

where the packet having the smallest value Fj among the scheduled transfer finish times Fj of the packets in the cluster 

Is selected as the first order packet of that cluster for each cluster Cj (j = 1 to M). 

[0095] Further, a parameter NCR (Next Cluster Pointer) indicating the pointer of the next order packet for maintaining 
the state where the packets in the cluster are sorted in the order from the smallest value of the scheduled transfer 
35 finish time Fj is added to the packets in the cluster. The packets can be linked each other, in the cluster, in the order 
of sorting by the parameter NCR 

[0096] The inside-cluster selecting means 3-5 has a function of calculating the scheduled transfer finish times Fj (= 
Oj + Pi X y) of the packets in a cluster by a request from the cluster managing means 3-4 for one of the clusters stored 
in the cluster managing means 3-4, selecting the packet having the smallest that value Fj among the scheduled transfer 

40 finish times Fj of the packets as the first order packet, and returning this to the cluster managing means 3-4. Further, 
it has a f unctbn of outputting the scheduled transfer finish time Fj of the first order packet to the output control means 3-7. 
[0097] The inside-cluster selecting means 3-5 can use, as mentioned before, the procedure of selecting the sched- 
uled transfer finish time from ocj and pj, the procedure of sorting, or the procedure of appropriately switching these two 
procedures In accordance with the processing time. 

45 [0098] The inter-cluster selecting means 3-6 calculates and selects the packet having the smallest value of the sched- 
uled transfer finish time Fj (= Oj + pj x y) from among the first order packets in the clusters C^ to Ci^^i (note, except the 
cluster which was output immediately before this) and outputs that scheduled transfer finish tinne Fj to the output control 
means 3-7. 

[0099] The output control means 3-7 compares the scheduled transfer finish times Fj input from the inside-cluster 
50 selecting means 3-5 and the inter-cluster selecting means 3-6, selects the packet having the smaller value Fj as the 
top priority packet to be transferred, and outputs the packet tag thereof. 

[0100] In order to perform similar processing with the next packet as the head packet for the queue Qj in which the 
tag of the packet transferred is stored, the output control means 3-7 activates the processing of the multi-queue man- 
aging means 3-1 , the reserved bandwidth use ratio 7 computing means 3-2, and the clustering means 3-3 for the next 
55 head packet. 

[0101] The functional means of the packet transfer control apparatus of the present inventk)n were explained above. 
Here, an explanatbn will be made below of the processing operation by referring to the same Fig. 3 while classifying 
the processing operation into packet output processing and packet input processing. Note that, in the figure, the circled 
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numbers correspond to the numbers in parentheses attached to the processing operation in the following explanation 
and represent the link positions among function modules to and from which the information concerning the related 
processing operations are input and output. Further, in the figure, the contents of the information input, output or held 
at the link or function modules are described in blocks a) to h) by attaching lead lines. 

5 

[1] Packet output processing 

[0102] When the two conditions of both the completion of the packet output (10) by the output control means 3-7 
and the output permission (11) of the next packet are satisfied, a request (12) for processing the next packet, as the 
10 head packet, in the queue Qj to which the packet which was output immediately before this belonged is sent from the 
output control means 3-7 to the multi-queue managing means 3-1 , the resen/ed bandwidth use ratio y computing means 
3-2. and the clustering means 3-3. 

[0103] The multi-queue managing means 3-1 calls up the new head packet if an untransferred packet is stored in 
the queue Q,, calculates the transfer start reference time <t^ of the head packet, and stores the calculated value in the 

IS meter. Note, if the related queue Qj has become empty, the multi-queue managing means 3-1 does not outputs anything. 
[0104] The transfer start reference time a,- is set as Oj = t when comparing the arrival time t of this packet and the 
scheduled transfer finish time Fj q of the packet sent immediately before this and t ^ Fj q, while is set as Oj = Fj q if t < Fj q. 
[0105] The muttl-queue managing means 3-1 outputs (15) the parameters of the packet length Lj and the reserved 
bandwidth to the clustering means 3-3. Further, the multi-queue managing means 3-1 outputs (14) the change (±<I>) 

20 of the available resen/ed bandwidth caused by the change of the active state of the queue to the reserved bandwidth 
use ratio y computing means 3-2. 

[0106] The clustering means 3-3 calculates (2) the scheduled resource occupatbn time p when the parameters are 
input, performs (3) the clustering for new head packets in accordance with this value p, and outputs the same to the 
cluster managing means 3-4. 

25 [0107] The reserved bandwidth use ratio y computing means 3-2 computes (13) the cumulative value of the 
resen/ed bandwidths of the backlog queues. When there is an output request (12) from the output control means 3-7. 
the cumulative value of the reserved bandwidths is output to the y computing means, and the y computing means 
computes (4) the reserved bandwidth use ratio y, that is, the ratio of the cumulative value of the resen/ed bandwidths 
with respect to the bandwidth R of the entire resources, and outputs the same to the inskJe-cluster selecting means 

30 3-5 and the inter-cluster selecting means 3-6. 

[0108] The cluster managing means 3-4 warts for exactly a perk>d for the clustering for the next head packet to be 
completed when the cluster Cj to which the packet selected as the top priority output packet belonged is notified from 
the output control means 3-7 and sends (7) all packets belonging to that cluster Cj to the inside-cluster selecting means 
3-5. The inside-cluster selecting means 3-5 newly selects the first order packet from among these packets and returns 

3S (9) the same to the cluster managing means 3-4. 

[0109] Further, when the next head packet is clustered into another cluster Ci^, all packets of the other cluster C,^ are 
similarly sent (7) to the inside-cluster selecting means 3-5. The inside-cluster selecting means 3-5 newly selects the 
first order packet from among these packets and returns (9) the same to the cluster managing means 3-4. 
[0110] The cluster managing means 3-4 outputs (5) the parameters (oj, Pj) of the first order packets in the clusters 

40 other than the cluster Cj finally sent to the inskle-cluster selecting means 3-5 to the inter-cluster selecting means 3-6. 
[0111] The inside-cluster selecting means 3-5 calculates the scheduled transfer finish times F, (= Oj + Pj x 7) of the 
packets by using parameters Oj and P| of the packets input (7) from the cluster managing means 3-4 and new reserved 
bandwidth use ratio y. selects the packet for which the scheduled transfer finish time Fj becomes the smallest from 
among these Fj as the first order packet, and outputs (8) this to the output control means 3-7 and, at the same time, 

4S returns (9) this to the cluster managing means. 

[0112] The inter-cluster selecting means 3-6 calculates the scheduled transfer finish times Fj (= ocj + Pj x y) by using 
parameters (ocj, pj) of the first order packets of the input clusters and the new reserved bandwidth use ratio y, selects 
the packet having the smallest Fj from among these Fj as a top priority candidate packet, and outputs this top priority 
candidate packet to the output control means 3-7 (6). 

so [0113] The output control means 3-7 selects and outputs (10) the packet having the smallest value of Fj from among 
the scheduled transfer finish times Fj input ((6), (8)) from the inter-cluster selecting means 3-6 and the inside-cluster 
selecting means 3-5 as the top priority transfer packet and, at the same time, requests (12) the processing with respect 
to the next output packet. 

ss [2] Packet input processing 

[0114] The multi-queue managing means 3-1 receives (1) the packet tags of the packets for performing the transfer 
sen/ice and stores the packet tags in the queues Qj corresponding to the flows. At this time, when a queue Qj is a 
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queue of the active state, the head packet has already existed in this queue, therefore, the input processing is finished 
by just adding the tag of the newly received packet to the queue Q;. 

[0115] When a packet arrives at a queue Q| in an empty state, this packet becomes the head packet, therefore the 
multi-queue managing means 3-1 calculates the transfer start reference time O} of the packet and sets the Oj in the 
s meter for the queue Qj, outputs (15) both the packet length Lj thereof and the reserved bandwidth Oj of the queue Qj 
to the clustering means 3-3, and outputs the amount of variation of the reserved use bandwidth (amount of increase 
a>i) to the reserved bandwidth use ratio y computing means 3-2. 

[0116] The clustering means 3-3 cak:ulates the scheduled resource occupation time P; by L/Oi at the p calculating 
unit, clusters the packets according to the value of the scheduled resource occupatbn time at the clustering process- 

10 ing unit C(Pi), and outputs (3) the result to the cluster managing means 3-4. 

[01 1 7] The cluster managing means 3-4, linked with the inside-cluster selecting means 3-5, calculates the scheduled 
transfer finish times Fj for the cluster Cj to which a packet is newly added based on the first order packet in the cluster 
Cj, the parameters (a, P) of the newly added packet, and the resented bandwidth use ratio y and selects and holds the 
packet having the smallest scheduled transfer finish time F| as the new first order packet. 

IS [0118] Figure 4 is an explanatory view of the packet transfer control by a plurality of schedulers according to the 
present invention. In the figure. 4-1 is an input link, 4-2 is a router (classifier), 4-3 Is a first multi-queue, 4-4 is a second 
multi-queue, 4-5 is a first sub-scheduler, 4-6 is a second sub-scheduler, and 4-7 is an upper main scheduler thereof. 
[0119] Figure 4 is an explanatory view for packet scheduling in a case where traffic packets of applications for which 
different qualities of sen^ice (Ck>S) are required are mixed such as the transfer of voice packets etc. where a low jitter 

20 is important or the transfer of WWW, FTP, and other data packets where a tow delay and maximum transfer capability 
are important. 

[0120] From the input link 4-1, traffic data having different quality of service (QoS) classes such as voice packets 
'Voice', video packets 'Video*, and data packets 'Data* are input. The router 4-2 analyzes the header information of 
the input packets to classify these packets into flows to which they betong and stores the packets in the queues cor- 

2S responding to the flows. 

[0121] The queues are comprised as a plurality of multi-queues controlled by different schedulers in accordance with 
the quality of sen/ice required by the corresponding flows of the queues. The first multi-queue 4-3 stores the packets 
for which low jitter is required, for example, voice packets 'Voice' and video packets 'Video'. The scheduling is con- 
trolled so that the predetermined output rate is guaranteed by the first sub-scheduler (S1 ) 4-5. 

30 [0122] The first sub-scheduler (SI ) 4-5 fixes rj q = rj ^ = <Dj in equation (1 ) mentioned above since it is not necessary 
to reallocate the remaining bandwidth among the queues, calculates the scheduled transfer finish times Fj ^ of the head 
packets in the queues to select the packet having the smallest value Fj as the top priority output packet. 
[0123] The first sub-scheduler (SI ) 4-5 has a light load of calculatton processing since the allocated bandwidth r; 
is a fixed value, so can perfonm priority selection processing following at high speed even for processing of a flow 

35 comprised by short packets like voice packets. 

[0124] On the other hand, packets for which a low delay is required like data packets are stored in the second multi- 
queue 4-4. The scheduling Is controlled so that the remaining bandwidth is fairly allocated by the weighted fair queueing 
(WFQ) by the second sub-scheduler (S2) 4-6. 

[0125] The weighted fair queueing (WFQ) has the excellent features of the guarantee of the minimum delay of the 
40 packets and the fair reallocation of remaining bandwidth among flows. The second sub-scheduler (52) 4-6 performs 
the clustering mentioned above in the calculation of the scheduled transfer finish times Fj ^ of the head packets in the 
queues, performs the cateulation processing at high speed by limiting the head packets to be cak:ulated, and selects 
the packet having the smallest value Fjj as the top priority output packet. 

[0126] The upper main scheduler (S) 4-7 links the first and second sub-schedulers (SI, S2), selects the packet 
45 having the smallest scheduled transfer finish time F|^ as the output packet for the output candidate of the packet 
selected from the two (SI , S2). and outputs this. 

[0127] By such processing, it is possible to guarantee low jitter and guarantee low delay for the flows in accordance 
with the quality of sen^ice (QoS) required by the flows and effectively utilizing the output link fairly among flows to the 
highest limit for the package transfer. 

so [0128] Summarizing the effects of the present invention, as explained above, in the processing of weighted fair 
queueing (WFQ) for selecting and transferring the head packet with the earliest scheduled transfer finish time from 
among the head packets in queues for which the scheduled transfer finish time varies due to the change of the sum 
value of the reserved bandwidths used by the backlog queues, by clustering the head packets with a low dependency 
of changes in the relative order of the scheduled transfer finish times on changes in the sum value of the reserved 

ss bandwidths of the backlog queues, calculating the scheduled transfer finish times with respect to only the first order 
packet in each queue by reusing the output priority order in each cluster calculated in the past as it is, and selecting 
the top priority packet, and thereby the amount of cateulation in the weighted fair queueing (WFQ) processing can be 
greatly reduced. 
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[0129] Further, in the calculation of the scheduled transfer finish time, the time axis is the real time axis, therefore 
the selection processing with respect to the packets with the top priority individually selected by a plurality of schedulers 
becomes easy and the selection processings by the plurality of schedulers can be easily linked. 



Claims 

1 . A packet transfer control apparatus comprising: 

a scheduler for controlling the transfer by weighting the order of transfer for each head packet in the queues, 
the scheduler comprising: 

means for dividing each head packet in the queues into clusters in accordance with the ratio between the 
packet length of the head packet in each queue and the reserved bandwidth of the packet, and 
means for selecting the packet having the earliest scheduled transfer finish time as the top priority transfer 
packet from among each first order packet Inskie the clusters. 

2. A packet transfer control apparatus provided with at least one scheduler which controls the transfer by weighting 
the order of transfer for the head packets in the queues in the order from the packet having the earliest scheduled 
transfer finish time for packets stored in a plurality of queues to which are allocated reserved bandwidths IndivkJually 
determined in advance and, at the same time. alkx:ating the resources (t>andwidths) to all of the active queues in 
which packets to be transferred are stored, 

wherein the scheduler is provided with: 

a clustering means for dividing the head packets in the queues into clusters in accordance with the ratio 
between the packet length of the head packet in each queue and the reserved bandwidth (hereinafter referred 
to as the scheduled resource occupation time), 

a cluster managing means for holding the packets having the earliest scheduled transfer finish times among 
the packets in a cluster for all clusters as the first order packets, 

an Inside-cluster selecting means tor selecting the packet having the earliest scheduled transfer finish time 
for the cluster as the first order packet when a packet is deleted or added inside the cluster, and 
an inter-cluster selecting means for selecting the packet having the earliest scheduled transfer finish time as 
the top priority transfer packet from among the first order packets inskie the clusters. 

3. A packet transfer control apparatus as set forth in claim 2, wherein: 

said scheduler is provided with a reserved bandwkJth use ratk) computing means for computing the ratio (here- 
inafter referred to as the reserved bandwidth use ratio) of a cumulative value of the resen/ed bandwidths for 
the active queues with respect to the resources (bandwidths) and 

said inter-cluster selecting means is structured to calculate the scheduled transfer finish time based on the 
transfer start reference time of each first order packet, the scheduled resource occupation time, and the re- 
sen/ed bandwidth use ratio. 

4. A packet transfer control apparatus as set forth in claim 2 or 3, wherein: 

said inside-cluster selecting means is structured to sort the packets in a cluster in the order from the earliest 
scheduled transfer finish time and 

said cluster managing means may be constituted so as to hold the packets sorted In the order from the earliest 
scheduled transfer finish time for every cluster. 

5. A packet transfer control apparatus as set forth in claim 2 or 3, wherein: 

said inside-cluster selecting means is structured to perform the selection by switching between processing for 
selecting only the first order packet having the earliest scheduled transfer finish time from the packets in a 
cluster and processing for sorting them in the order from the one having the earliest scheduled transfer finish 
time, 

perform the processing for sorting in the order from the one having the earliest scheduled transfer finish time 

when the transfer time of a packet in transmission is more than a predetermined time, and 

perform the processing for selecting only the first order packet having the earliest scheduled transfer finish 
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time when the transfer tlrne of the packet in transmission is not nnore than a predetermined time. 

6. A packet transfer control apparatus as set forth in any one of claims 2. 3, and 5. wherein the inside-cluster selecting 
means is constituted so as to select the packet having the earliest scheduled transfer finish time based on only 

5 said transfer start reference time of each packet in the cluster or said transfer start reference time and said sched- 

uled resource occupation time. 

7. A packet transfer control apparatus as set forth in claim 4 or 5, wherein said inside-cluster selecting means is 
constituted so as to sort the packets in the cluster in the order from the one having the earliest scheduled transfer 

10 finish time based on only said transfer start reference time of each packet in the cluster or said transfer start 
reference time and said scheduled resource occupation time. 

8. A packet transfer control apparatus as set forth in any one of claims 2 to 7, wherein said clustering means is 
constituted so as to divide the head packets in the queues into clusters by discriminating the type of the application 

IS packet having traffic characteristbs for which the scheduled resource occupation time is specified. 

9. A packet transfer control apparatus as set forth In any one of claims 2 to 8. wherein: 

provision is made of a plurality of schedulers which perform different processing for allocation of the resources 
of the entire transmission system for packets stored in multi-queues differing for all clusters in accordance 
with the class of the quality of service. 

each scheduler is provided with a means for selecting the packet having the earliest scheduled transfer finish 
time from among the head packets for every multi-queue, and 

provision is made of a scheduler for selecting the packet having the earliest scheduled transfer finish time 
from among packets selected by the schedulers corresponding to the multi-queues. 

10. A packet transfer control apparatus as set forth in claim 9, wherein at least one scheduler among said schedulers 
corresponding to the multi-queues is provided with a means for allocating bandwidths of a fixed rate to queues in 
the corresponding multi-queues and selecting the packet having the earliest scheduled transfer finish time. 

11. A packet transfer scheduling method which transfers packets by weighting the order of transfer for head packets 
of queues in the order from the packet having the earliest scheduled transfer finish time for packets stored in a 
plurality of queues to which are allocated at least reserved bandwidths individually determined in advance and, at 
the same time, allocating resources (bandwidths) to all of the active queues in which packets to be transferred are 
stored, comprising: 

a step of dividing the head packets of the queues into clusters in accordance with scheduled resource occu- 
pation times of the head packets in the queues, 

a step of selecting the packet having the earliest scheduled transfer finish time for a cluster as a first order 
packet when a packet is deleted or added to packets in the cluster and holding this selected packet, and 
a step of selecting the packet having the earliest scheduled transfer finish time from among the first order 
packets In the clusters as a top prbrity transfer packet. 

12. A packet transfer scheduling method as set forth in claim 11, further comprising a step of computing a reserved 
^ bandwidth use ratio of active queues and a step of calculating a scheduled transfer finish time during the selection 

among clusters based on the transfer start reference time of the first order packet, the scheduled resource occu- 
patbn time, and the reserved bandwidth use ratio. 

1 3. A packet transfer scheduling method as set forth in claim 1 1 or 1 2, further comprising, when achieving the selection 
so in the clusters, a step of sorting the packets in a cluster in the order from the earliest scheduled transfer finish time 

and holding the sorted packets. 

14. A packet transfer scheduling method as set forth in claim 11 orl 2, further comprising, when achieving the selection 
in the clusters, a step of performing processing for sorting in the order from the packet having the earliest scheduled 

ss transfer finish time when the transfer time of a packet in transmission is more than a predetermined time and 

performing processing for selecting only the first order packet having the earliest scheduled transfer finish time 
when the transfer time of the packet in transmlssbn is not more than a predetermined time. 



20 



25 



30 



3S 



15 



EP0989770A1 



15. A packet transfer scheduling method as set forth in claim 11, 12, or 14. further comprising, when achieving the 
selection in the clusters, a step of selecting the packet having the earliest scheduled transfer finish time based on 
only the transfer start reference time of each packet in the cluster or the transfer start reference time and the 
scheduled resource occupation time. 

5 

1 6. A packet transfer scheduling method as set forth in claim 1 3 or 1 4, further comprising, when achieving the selection 
in the clusters, a step of sorting the packets in the cluster in the order from the one having the earliest scheduled 
transfer finish time based on only the transfer start reference time of each packet in the cluster or the transfer start 
reference time and the scheduled resource occupatton time. 

10 

17. A packet transfer scheduling method as set forth in any one of claims 11 to 1 6, further comprising, when achieving 
the selection in the clusters, a step of dividing the head packets of queues into clusters by discriminating the type 
of the application packet having traffic characteristics for which the scheduled resource occupation time is specified. 
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